/** * BSD-style license; for more info see http://pmd.sourceforge.net/license.html */ package test.net.sourceforge.pmd.rules; import net.sourceforge.pmd.PMD; import net.sourceforge.pmd.Rule; import net.sourceforge.pmd.RuleSetNotFoundException; import test.net.sourceforge.pmd.testframework.SimpleAggregatorTst; import test.net.sourceforge.pmd.testframework.TestDescriptor; public class UnnecessaryConstructorRuleTest extends SimpleAggregatorTst { private Rule rule; public void setUp() throws RuleSetNotFoundException { rule = findRule("rulesets/controversial.xml", "UnnecessaryConstructorRule"); } public void testAll() { runTests(new TestDescriptor[] { new TestDescriptor(TEST1, "simple failure case", 1, rule), new TestDescriptor(TEST2, "private constructor", 0, rule), new TestDescriptor(TEST3, "constructor with arguments", 0, rule), new TestDescriptor(TEST4, "constructor with contents", 0, rule), new TestDescriptor(TEST5, "constructor throws exception", 0, rule), new TestDescriptor(TEST6, "two constructors", 0, rule), new TestDescriptor(TEST7, "inner class with unnecessary constructor", 1, rule), new TestDescriptor(TEST8, "inner and outer both have unnecessary constructors", 2, rule), new TestDescriptor(TEST9, "inner and outer, both ok", 0, rule), new TestDescriptor(TEST10, "inner ok, outer bad", 1, rule), new TestDescriptor(TEST11, "inner ok due to nonpublic constructor", 0, rule), new TestDescriptor(TEST12, "constructor calls super", 0, rule), new TestDescriptor(TEST13, "constructor calls super, no args", 1, rule), }); } private static final String TEST1 = "public class Foo {" + PMD.EOL + " public Foo() {}" + PMD.EOL + "}"; private static final String TEST2 = "public class Foo {" + PMD.EOL + " private Foo() {}" + PMD.EOL + "}"; private static final String TEST3 = "public class Foo {" + PMD.EOL + " public Foo(int x) {}" + PMD.EOL + "}"; private static final String TEST4 = "public class Foo {" + PMD.EOL + " public Foo() { " + PMD.EOL + " int x = 2;" + PMD.EOL + " }" + PMD.EOL + "}"; private static final String TEST5 = "public class Foo {" + PMD.EOL + " public Foo() throws IOException { " + PMD.EOL + " }" + PMD.EOL + "}"; private static final String TEST6 = "public class Foo {" + PMD.EOL + " public Foo() {" + PMD.EOL + " }" + PMD.EOL + " public Foo(String foo) {}" + PMD.EOL + "}"; private static final String TEST7 = "public class Foo {" + PMD.EOL + " public class Inner {" + PMD.EOL + " public Inner() {}" + PMD.EOL + " }" + PMD.EOL + "}"; private static final String TEST8 = "public class Foo {" + PMD.EOL + " public class Inner {" + PMD.EOL + " public Inner() {}" + PMD.EOL + " }" + PMD.EOL + " public Foo() {}" + PMD.EOL + "}"; private static final String TEST9 = "public class Foo {" + PMD.EOL + " public class Inner {" + PMD.EOL + " }" + PMD.EOL + "}"; private static final String TEST10 = "public class Foo {" + PMD.EOL + " public class Inner {" + PMD.EOL + " }" + PMD.EOL + " public Foo() {}" + PMD.EOL + "}"; private static final String TEST11 = "public class Foo {" + PMD.EOL + " public class Inner {" + PMD.EOL + " private Inner() {}" + PMD.EOL + " }" + PMD.EOL + "}"; private static final String TEST12 = "public class Foo {" + PMD.EOL + " public Foo() {super(7);}" + PMD.EOL + "}"; private static final String TEST13 = "public class Foo {" + PMD.EOL + " public Foo() {super();}" + PMD.EOL + "}"; }